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REPRODUCIBLE SELECTION OF MEMBERS IN A HIERARCHY 



TECHNICAL FIELD OF THE INVENTION 

This invention relates to the field of data selection and manipulation, and more 
particularly to reproducible selection of members in a hierarchy. 
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BACKGROUND OF THE INVENTION 

It is often desirable within a business or other planning environment to 
generate and/or analyze information regarding sales, demand, supply, selling price, or 
other data concerning a product or other item. Data for products may often be 
5 dependent in some manner on data for other hierarchically related products. For 
example, sales of products in a particular geographic region may be reflect sales for 
the products in a particular territory in the region. Because of these hierarchical 
dependencies, the data concerning various products or other items may be stored 
hierarchically in data storage or derived in a hierarchical fashion. Furthermore, the 

10 data may be stored at a storage location associated with multiple dimensions, such as 
a product dimension (the storage location being associated with a particular product or 
product component), a geography dimension (the storage location being associated 
with a particular geographical area), and a time dimension (the storage location being 
associated with a particular time or time period). 

15 It is often desirable to select a subset of the members of a hierarchical 

dimension for use in a particular process (for example, to view planning data 
associated with particular products). The hierarchical dimensions reflect real world 
structures in the organization and these structures can change on a frequent basis. 
When members of a hierarchical dimension are added or deleted, have their position 

20 in the hierarchy changed, or have other characteristics changed on a frequent basis, a 
"hard coded" set of members used to perform a particular business process or function 
may quickly become out of date and have to be recreated. This process is time- 
consuming and inefficient and hampers the planning or other functions of a business. 
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SUMMARY OF THE INVENTION 

According to the present invention, disadvantages and problems associated 
with previous hierarchical member selection techniques have been substantially 
reduced or eliminated. 

According to one embodiment of the present invention, a method for selecting 
members in a hierarchy includes determining a sequence of one or more actions 
associated with a member selection tree. The actions collectively selecting one or 
more members from a hierarchy of members. The hierarchy of members is associated 
with a particular dimension of an organization of data. The method further includes 
recording the sequence of actions in a member selection script. In addition, the 
method includes executing the member selection script to select one or more members 
after the hierarchy of members has been modified. 

Embodiments of the present invention may provide one or more technical 
advantages. For example, particular embodiments include a system that allows a user 
to select members from a hierarchical dimension and that can then reproduce a 
selection of members that meets the same end purpose as the user's selection after the 
hierarchy members or their relationships change. Such embodiments allow the steps 
of a user-defined workflow created through a user interface to be quickly defined in a 
generic and reusable manner. Rather than remembering the members that are 
selected, such a system remembers the sequence of events the user went through to 
determine the members that were selected. This sequence of events can then be 
repeated once the hierarchy is modified and produce a new selection of members that 
satisfies the user's original intent. 

The effective life of such member selection processes may be a significant 
length of time, spanning many cycles of changes or reorganizations of the underlying 
hierarchical dimension. This significantly reduces the effort necessary to support a 
planning or other process that uses the selected members as input and also helps to 
ensure that the selection continues to be the members that satisfy the original intent of 
the user, even where there may be changed circumstances (including those of which 
the user is unaware). Without such a system, the user may have to constantly recreate 
the member selections (thus wasting time that would be better employed in the 
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business process) or risk that the wrong information will be used in the process due to 
the selection not being up to date. 

Other important technical advantages are readily apparent to those skilled in 
the art from the figures, descriptions, and claims included herein. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

To provide a more complete understanding of the present invention and the 
features and advantages thereof, reference is made to the following description taken 
in conjunction with the accompanying drawings, in which: 

FIGURE 1 illustrates an example system for storing and using a hierarchical 
organization of data; 

FIGURE 2 illustrates an example product dimension within a multi- 
dimensional organization of data; 

FIGURE 3 illustrates an example geography dimension within a multi- 
dimensional organization of data; 

FIGURE 4 illustrates an example member selection interface; 

FIGURE 5 illustrates an example hierarchy upon which a member selection 
script may operate; and 

FIGURE 6 illustrates an example method for creating and reproducing 
member selections. 
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DESCRIPTION OF EXAMPLE EMBODIMENTS 

FIGURE 1 illustrates an example system 10 for storing and using a 
hierarchical organization of data associated with a business or other planning 
environment. As described below, system 10 may be used to access and store values 
5 associated with particular data members in a data storage device or in a representation 
of data. As examples only, these values may include actual sales, forecasted sales, 
actual demand, forecasted demand, available supply, selling price, or any other 
quantifiable data measure associated with a particular product or other item. 
Furthermore, although products are typically referred to herein, system 10 may be 

10 used to store and access data for appropriate tangible or non-tangible items other than 
products, including but not limited to services or other benefits. 

Example system 10 includes a server 12, a client 14, and data storage 16. 
Server 12 may include one or more processes to receive administration, analysis, and 
planning input from client 14 and interact with data storage 16 to provide 

15 corresponding output to client 14. These processes may be separate processes 
running on a dedicated processor or these processes may be integrated, in whole or in 
part, and run on one or more processors within the same or different computers. 
Similarly, client 14 may include one or more processes that provide appropriate data 
administration, analysis, and planning input. These processes may be separate 

20 processes running on a dedicated processor or these processes may be integrated, in 
whole or in part, and run on one or more processors within the same or different 
computers. Client 14 and server 12 may be fully autonomous or may operate at least 
in part subject to input from users of system 10. Furthermore, although system 10 is 
described as including client 14 and server 12, any other appropriate components for 

25 storing, accessing, managing, manipulating, or otherwise using hierarchical data 
associated with data storage 16 may also or alternatively be included in system 10. 

The term "data storage" is used to refer to any appropriate data source, 
representation of data, or other organization of data. Data storage 16 may be 
hierarchical in nature, may be multi-dimensional, and/or may provide persistent data 

30 storage for system 10. For example, data storage 16 may be a multi-dimensional 
database that stores data in a hierarchical and multidimensional format or data storage 
16 may be a representation of data derived by server 12 or other appropriate 
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component from data stored in a relational database, in memory, or in any other 
appropriate location. In one embodiment, data storage 16 includes three-dimensional 
data and, for each data measure, associates with each storage location 1 8 a particular 
member from the product dimension, a particular member from the geography 
5 dimension, and a particular member from the time dimension. Each of these 
particular combinations of members of these three dimensions is associated with a 
corresponding storage location 18 in data storage 16, similar to each combination of 
coordinates from the x, y, and z axes being associated with a point in three- 
dimensional Euclidian space. Furthermore, position within a particular dimension 

10 may be changed independent of members of other dimensions, much like the position 
of a coordinate along the x axis may be changed independent of the positions of other 
coordinates along the y and z axes in three-dimensional Euclidian space. 

Data storage 16 may have as few or as many dimensions as appropriate for the 
particular application. For example, and not by way of limitation, an enterprise 

15 associated with system 10 may not consider geography in connection with its data 
usage. This might be the case when products are ordered using the Internet or the 
telephone and then distributed from a single distribution point. In this example, data 
storage 16 might be two-dimensional rather than three-dimensional and might not 
reflect positions or members within the geography dimension. Furthermore, the data 

20 might be tracked by time, in which case data storage 16 might be two-dimensional 
and might not reflect positions or members within the time dimension. Other possible 
scenarios involving more or fewer than three dimensions will be apparent to those 
skilled in the art. For example, instead of or in addition to a geography dimension, 
data storage 16 may have a location dimension, a store dimension, or an outlet 

25 dimension used to organize the various physical locations where products might be 
sold. As further examples, data storage 16 might include a supplier dimension or a 
customer dimension. Data storage 16 may have any number of dimensions 
appropriate for the needs of the enterprise or facility associated with system 10. 

In the three-dimensional example above, the values of the data measures 

30 within the set for a particular storage location 18 depend on the combined positions of 
members within product, geography, and time dimensions for that storage location 18. 
As a result, the values of the data measures typically vary with these combined 
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positions as appropriate to accurately reflect the sales, demand, available supply, 
selling price, or other data associated with these members. As described below, when 
a suitable combination of members is specified in the product, geography, and time 
dimensions according to operation of system 10, data storage 16 accesses the data 
measures for storage location 18 associated with that combination of members. Other 
suitable dimensions may replace or be combined with the product, geography, and 
time dimensions according to particular needs. 

In one embodiment, data storage 16 supports multi-dimensional on-line 
analytical processing (OLAP) capability and is populated with data measures received 
from one or more transactional data sources that are internal, external, or both internal 
and external to the enterprise or facility associated with system 10. For example, and 
not by way of limitation, data measures received from sources internal to a 
manufacturing or warehousing facility may include unit shipping data, dollar shipping 
data, inventory data, pricing data, and any other suitable information. Data measures 
received from external sources, such as from syndicated partners of the enterprise or 
facility, may include point-of-sale demographic data and any other suitable 
information. Other data that may also or alternatively stored in data storage 16 
includes planning data such as plans, forecasts, projections, or the like that are 
generated by system 10 or a user associated with system 10. Appropriate data 
measures may be stored in data storage 16 in any suitable manner. 

System 10 may operate on one or more computers 20 that are integral to or 
separate from the hardware and/or software that support server 12, client 14, and data 
storage 16. Computer 20 may include a suitable input device 22, such as a keypad, 
mouse, touch screen, microphone, or other device to input information. An output 
device 24 may convey information associated with the operation of system 10, 
including digital or analog data, visual information, or audio information. Computer 
20 may include fixed or removable storage media, such as magnetic computer disks, 
CD-ROM, or other suitable media to receive output from and provide input to system 
10. Computer 20 may include one or more processors 26 and associated memory to 
execute instructions and manipulate information according to the operation of system 
10. Although only a single computer 20 is shown, server 12, client 14, and data 
storage 16 may each operate on separate computers 20 or may operate on one or more 
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shared computers 20. Each of the one or more computers 20 may be a work station, 
personal computer (PC), network computer, personal digital assistant (PDA), wireless 
data port, or any other suitable computing device. 

Server 12 is coupled to data storage 16 using link 32, which may be any 
5 wireline, wireless, or other link suitable to support data communications between 
server 12 and data storage 16 during operation of system 10. Data storage 16 may be 
integral to or separate from server 12, may operate on one or more computers 20, and 
may store any information suitable to support the operation of system 10. Server 12 is 
coupled to client 14 using link 30, which may be any wireline, wireless, or other link 

10 suitable to support communications between server 12, client 14, and the processes of 
server 12 and client 14 during operation of system 10. Although link 30 is shown as 
generally coupling server 12 to client 14, processes of server 12 may communicate 
directly with one or more corresponding processes of client 14. 

FIGURE 2 illustrates an example product dimension 50 within data storage 16 

15 that includes a hierarchy of product levels 52 each having one or more members 54. 
Although one example hierarchy is illustrated, it should be understood that a 
dimension may have multiple alternative hierarchies. The value of each data measure 
associated with a member 54 may be an aggregation of the values of corresponding 
data measures associated with hierarchically related members 54 in lower levels 52 of 

20 product dimension 50. In an example embodiment in which system 10 provides sales 
forecasts, the sales associated with a member 54 is the aggregate sales for these 
hierarchically related members 54 in lower levels 52 of product dimension 50. In the 
illustrated embodiment, product levels 52 for product dimension 50 include an all 
products level 58, a product type level 60, a product category level 62, and a product 

25 family level 64. Selected and merely example hierarchical relationships between 
members 54 are shown using links 56, as described more fully below. Links 56 
between hierarchically related members 54 in adjacent levels 52 of product dimension 
50 reflect parent-child relationships between members 54. Although FIGURE 2 is 
described primarily in connection with sales relationships, the following description is 

30 similarly applicable to other data relationships, such as demand, available supply, 
selling price, or any other relationships relating to data measures associated with an 
item or set of items. Furthermore, although described above, the value of measures at 
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aggregated levels may not always be a simple aggregation. A number of alternative 
aggregation techniques may be used including, but not limited to, averages, minima 
and maxima, and (in the time dimension) first and last (for example, the value for a 
month is the value of the first or last week in a month). Values of measures at 
5 aggregated levels may also be determined by applying a rule. For example, one 
example measure is "selling price." Such a measure generally cannot be generated at 
aggregated levels by any form of aggregation, but can only be generated by applying 
a rule (for example, (aggregated) sales dollars divided by (aggregated) sales units). 
Any other appropriate rules may similarly be used. 

10 In the particular example shown in FIGURE 2, all products level 58 contains 

"All" member 54 representing the aggregate sales for all members 54 in lower levels 
60, 62, and 64 of product dimension 50. Product type level 60 contains 
"Components," "Base Units," and "Options" members 54. "Components" member 54 
represents the aggregate sales for hierarchically related members 54 below 

15 "Components" member 54 in levels 62 and 64 of product dimension 50. Similarly, 
"Base Units" member 54 represents the aggregate sales for hierarchically related 
members 54 below "Base Units" member 54 and "Options" member 54 represents the 
aggregate sales for hierarchically related members 54 below "Options" member 54. 
Links 56 between "All" member 54 and "Components," "Base Units," and "Options" 

20 members 54 indicate the hierarchical relationships between these members 54. 

Product category level 62 contains, under "Components" member 54, "Hard 
Drives," "Memory Boards," and "CPUs" members 54. "Hard Drives" member 54 
represents the aggregate sales for hierarchically related members 54 below "Hard 
Drives" member 54 in level 64 of product dimension 50. Similarly, "Memory 

25 Boards" member 54 represents aggregate sales for hierarchically related members 54 
below "Memory Boards" member 54 and "CPUs" member 54 represents the aggregate 
sales for hierarchically related members 54 below "CPUs" member 54. Links 56 
between "Components" member 54 and "Hard Drives," "Memory Boards," and 
"CPUs" members 54 indicate the hierarchical relationships between these members 

30 54. Analogous links 56 reflect hierarchical relationships between "Base Units" and 
"Options" members 54 of product type level 60 and corresponding members 54 in 
lower levels 62 and 64 within product dimension 50. 
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Product family level 64 contains, under "Hard Drives" member 54, "4GB" and 
"6GB" members 54. Links 56 between "Hard Drives" member 54 and "4GB" and 
"6GB" members 54 indicate hierarchical relationships between these members 54. 
Analogous links 56 reflect hierarchical relationships between "Memory Boards," 
"CPUs," "Servers," "Desktops," "Laptops," "Monitors," "Keyboards," and "Printers" 
members 54 of product category level 62 and corresponding members 54 in lower 
level 64 within product dimension 50. Although no links 56 are shown between 
members 54 in product family level 64 and possible lower levels 52, such further 
levels 52 may exist within product dimension 50 and analogous links 56 may exist to 
reflect the corresponding hierarchical relationships. Furthermore, members 54 shown 
in FIGURE 2 are example only and are not intended to be an exhaustive set of all 
possible members 54. Those skilled in the art will appreciate that other suitable 
members 54 and associated links 56 may exist. 

FIGURE 3 illustrates an example geography dimension 70 within data storage 
16 that includes a hierarchy of geography levels 72 each having one or more members 
74. Although one example hierarchy is illustrated, it should be understood that a 
dimension may have multiple alternative hierarchies. The value of each data measure 
associated with a member 74 may be an aggregation of the values of corresponding 
data measures associated with hierarchically related members 74 in lower levels 72 of 
geography dimension 70 (although other aggregation techniques may be used, as 
described above). In the example embodiment in which system 10 provides sales 
forecasts, the sales associated with a member 74 is the aggregate sales for these 
hierarchically related members 74. In this embodiment, geography levels 72 for 
geography dimension 70 include a world level 78, a country level 80, a region level 
82, and a district level 84. Selected and merely example hierarchical relationships 
between members 74 are shown using links 76, which are analogous to links 56 
described above with reference to FIGURE 2. Although FIGURE 3 is described 
primarily in connection with sales relationships, the following description is similarly 
applicable to other data relationships, such as demand, available supply, selling price, 
or any other relationships relating to one or more data measures associated with an 
item or set of items. 

In the particular example illustrated in FIGURE 3, world level 78 contains 



ATTORNEY'S D 
020431.1081 




.■JET 




ENT APPLICATION 



12 



"World" member 74 representing aggregate worldwide sales. Country level 80 
contains "U.S." and "Canada" members 74, which represent aggregate sales for the 
United States and Canada, respectively. Link 76 between "U.S." members 74 in 
country level 80 and "World" members 74 in world level 78 indicates a hierarchical 
5 relationship between these members 74. Similarly, link 76 between "Canada" 
member 74 and "World" member 74 indicates a hierarchical relationship between 
these members 74. In this example, worldwide sales is an aggregation of aggregate 
sales in the United States as well as aggregate sales in Canada. Although other links 
76 are not described in detail, those skilled in the art will appreciate that links 76 are 

10 analogous to links 56 described above with reference to FIGURE 2 in that each 
represents a corresponding hierarchical relationship between members 74 in the 
various levels 72 of geography dimension 70. As discussed above, geography 
dimension 70 may be eliminated or otherwise not considered in allocating data, for 
example, if geography dimension 70 is not relevant to particular data forecasting 

15 needs. Data storage 16 might in this situation be two-dimensional. 

Sales or other forecasts may be derived using traditional forecasting 
techniques and suitable information concerning products, geographic areas, 
customers, and/or other data dimension. Such information may include historical 
sales, causal factors, key account input, market intelligence, and the like. Forecasting 

20 techniques may rely on hierarchical relationships between members 54, 74 to allocate 
data forecasts for products corresponding to members 54, 74. As described above, the 
data measures associated with each member 54, 74 are an aggregation of the data 
measures associated with some or all members 54, 74 in lower levels 52, 72 within 
the same hierarchy of parent-child links 56, 76. Therefore, given forecast data for a 

25 member 54, 74 (a parent) at one level 52, 72, the forecasts for each of the related 
members 54 in the next lowest level 52, 72 (the children of the parent) may be 
determined by disaggregating the forecast data for the parent between the children. 
Furthermore, although the terms "parent" and "children" are used above to identify a 
relationship between members 54, 74 of a single dimension 50, 70, these terms may 

30 also be used to refer to the relationship between data measures or values associated 
with a storage location 18 associated with a member from each of a number of 
dimensions. For example, a storage location 18 that includes a sales value for a 
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particular product in a particular state may be hierarchically related to a storage 
location 18 that includes a sales value for the product in a city of that state (the value 
associated with the former storage location 1 8 being a parent of the value associated 
with the latter storage location 18). 
5 In addition to sales or other data forecasting, numerous other operations may 

be performed on the data in data storage 16 and data associated with particular 
members may be accessed for a variety of reasons. In many such cases, a user may 
desire or be required to select a subset of the members of a hierarchical dimension for 
use in a particular process (such as viewing planning data or allocating particular 

10 data). As described above, the dimensions (such as dimensions 50 and 70) reflect 
actual structures in the organization. In many types of businesses, these structures can 
frequently change. When members of a hierarchical dimension are added or deleted, 
have their position in a hierarchy changed, or have other characteristics changed on a 
frequent basis, a "hard coded" set of members used to perform a particular business 

1 5 process or function may quickly become out of date and have to be recreated. This 
process is time-consuming and inefficient are hampers the planning or other functions 
of a business. 

System 10 provides a technique for recording the selection of members that 
overcomes these problems. This technique, rather than recording the particular 

20 members that are selected, remembers the sequence of events the user went through to 
determine the members that are selected. This sequence of events can then be 
repeated once the hierarchy is modified and produce a new selection of members that 
satisfies the user's original intent. The effective life of such member selection 
processes may be a significant length of time, spanning many cycles of changes or 

25 reorganizations of the underlying hierarchical dimension. This significantly reduces 
the effort necessary to support a planning or other process that uses the selected 
members as input and also helps to ensure that the selection continues to be the 
members that satisfy the original intent of the user, even where there may be changed 
circumstances (including those of which the user is unaware). Without such a system, 

30 the user may have to constantly recreate the member selections (thus wasting time 
that would be better employed in the business process) or risk that the wrong 
information will be used in the process due to the selection not being up to date. 
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System 10 (for example, using server 12 and/or client 14) may provide one or 
more user interfaces that implement a member selection process. Such an interface 
may display one or more hierarchies of members included in one or more dimension 
as a "tree-like object." Such tree-like objects are often used in applications such as 
5 file directory viewers to illustrate the various hierarchical folders or directories 
included on a storage device. As with these folders or directories, members in a 
hierarchy may be selected and branches of the hierarchy may be expanded or 
collapsed using a user input device 22, such as a mouse. Furthermore, this user 
interface that can save a sequence of user inputs used to select particular members and 

10 can "replay" these inputs to generate a new selection of members based upon the 
members and hierarchical relationships present when the inputs are replayed. 

FIGURE 4 illustrates an example member selection interface 100 that may be 
provided by system 10. Member selection interface 100 provides a user with the 
ability to navigate through a hierarchy of members and select particular members the 

15 user desires for a particular function. Interface 100 provides a dimension "drop- 
down" menu 102 or other dimension selection tool that allows a user to select a 
particular data dimension from which members are to be selected. For example, the 
user may select a product dimension, a geography dimension, a time dimension, or 
any other appropriate dimension. Interface 100 allows a user to select members from 

20 one of the hierarchies that are valid in the current context and for the selected 
dimension. The current context is the portion of the data in data storage 16 to which 
the particular user has access or in which the particular user is interested. A hierarchy 
"drop-down" menu 104 or other hierarchy selection tool may be provided in interface 
100 to allow the user to select a hierarchy associated with the selected dimension. 

25 Furthermore, interface 100 includes a level selection table 106 that identifies 

each of the levels included in the selected hierarchy. The name of each level in the 
hierarchy is displayed along with a level selection box 108 or other selection tool that 
allows the user to indicate the selection of one or more levels in the hierarchy. The 
level selection dictates what levels are shown in a member selection tree 110 that is 

30 also included in interface 100. Member selection tree 1 10 may hierarchically display 
the members included in one or more of the levels selected in table 106. Interface 100 
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may include a button 1 12 that the user may select to apply the selection of levels in 
table 106 to tree 110. 

Tree 1 10, like many file navigation tools, allows a user to navigate through the 
nodes of the tree (in this case, the members of the hierarchy) and to collapse and 
5 expand members in tree 1 10. The user may select a particular member and collapse 
or expand the portion of the hierarchy below the selected member. For example, 
clicking on a next to a member may expand the tree below the member and 
clicking on a next to a member may collapse the tree below the member. Interface 
100 may also provide an option that, when selected by the user, fully expands every 

10 descendant of a selected member. As described below, the user may select one or 
more of the members in tree 1 10 to be used in performing a particular function. The 
members that are selected may form a "member query" that may be communicated to 
an appropriate destination (such as server 12) to identify the members that are 
relevant to the particular function. Interface 100 may provide a name edit box 114 

15 that displays the name of the member query currently being created (through the 
selection of members in tree 1 10) to allow the user to subsequently retrieve the query 
for reuse. 

Each member in tree 110 may have associated flags (such as Boolean state 
flags). One first such flag may be a selection flag that indicates whether the 

20 associated member has been selected by the user. Another flag may indicate whether 
the member has been expanded or collapsed. It should be noted that a child may be 
expanded even if its parent is collapsed. 

There are three core actions that a user may perform on tree 110. The first 
such action is selecting or deselecting a member. As an example, a user may click or 

25 double-click on a member to select or deselect the member. In particular 
embodiments, if the member is expanded (the children of the member are shown in 
tree 110), this action will only select or deselect the member itself. If the member is 
collapsed, this action will select or deselect the member and all descendents of the 
member. The second action that the user may perform is expanding or collapsing a 

30 member. This action sets the state of a member as to whether its direct children 
should or should not be displayed in the tree. 
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The third action that the user may perform using tree 110 is to accept the 
members that have been selected and use these members to form a member query. 
For example, a user may select a "Get Data" button 1 16 or other appropriate button to 
accept a particular selection of members. In particular embodiments when the user 
5 accepts the current selection, all members that are both visible and selected are 
included in the member query. System 10 can determine whether a member is visible 
in the tree based on the collapsed/expanded flags, A member is visible if all its 
ancestors have the expanded flag set. 

As described above, it is desirable to record a selection of members for later 

10 use. However, simply recording a "snapshot" of the selected members in the current 
hierarchy tree has the problem of recreating the desired member selections when the 
underlying hierarchical structures change. For example, if a class is moved from 
department to department (thus moving a member) or if a new store is added in a 
particular region (thus adding a member), then the tree must automatically reflect the 

15 new structures when it is next loaded. The approach implemented in system 10 
addresses these problems by recording the sequence of actions that the user took to 
select particular members and persists these actions instead of the actual tree. The 
sequence of actions may then be replayed to generate a desirable member selection. 

The member selections may be persisted by creating a member selection script 

20 that may be used to record and reproduce the actions taken by a user in interface 100. 
The term "script" as used herein should be understood to include all appropriate 
formats and techniques for recording user actions so as to allow the actions to be 
reproduced upon execution of the "script." Such a script may include a sequence of 
commands and associated parameters. Although example commands and parameters 

25 are described below, it should be understood that the following script concepts may be 
implemented in any appropriate manner using any suitable format. For example, an 
XML format may be used as an alternative to the example format described below. 

One command that may be used in a member selection script is a hierarchy 
selection (or HIERSELECT) command. An example of such a command is as 

30 follows: 
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HIERSELECT: hiercode [MODE= FRESH\SWITCH\MULTI] 
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The HIERSELECT command changes the hierarchy on which subsequent script 
commands operate. A HIERSELECT command may be added to a member selection 
script when a user selects a hierarchy using hierarchy "drop-down" menu 104 or other 
5 hierarchy selection tool of interface 100. 

A script may operate concurrently on multiple hierarchies. In such cases, 
system 10 maintains a selection tree 110 for each of the hierarchies that have been 
selected. In the example HIERSELECT command, a hiercode parameter may be used 
to specify the code of the hierarchy (alternatively, a hierarchy name may be 

10 specified). The MODE parameter determines how multiple hierarchies are dealt with. 
If MODE=FRESH is specified (which may be the default), the new hierarchy that is 
specified in the command is selected and all previous members selections are not 
considered. If MODE=SWITCH is specified, the new hierarchy that is specified in 
the command is selected and all previous members selections in any previous 

15 hierarchies are not considered, but the member selections in the previous selections 
are applied to the new hierarchy. If the members are not valid in the new hierarchy 
then their selection is ignored. If MODE=MULTI is specified, then all member 
selections in any previous hierarchies are retained. 



20 script also provides the ability to designate the selection of particular levels in the 
selected hierarchy. The script may use a leveljcl parameter to provide the ability to 
designate a level included in the selection hierarchy. An example syntax of the 
leveljcl parameter is as follows: 



A level may be specified using the level _id parameter in a number of different ways. 
For example, a levelcode may be used to identify a level using a level code generated 
by system 10 or specified by a user. A level may also be identified using the TOP 
30 parameter, which identifies the highest level in tree 110. A numeric parameter may 
supplied with the TOP parameter to identify a level that is n levels down from the 
highest level. Alternatively, a level may be identified using the BOTTOM parameter, 



In addition to providing commands to select hierarchies, the member selection 



25 



level Jd: levelcode \ TOP [+n] \ BOTTOM [+n] 
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which identifies the lowest level in tree 110. A numeric parameter may be supplied 
with the BOTTOM parameter to identify a level that is n levels up from the lowest 
level. 

It should be noted that one advantage of providing relative selection of levels 
5 (for example, TOP +2) arises when the context in which the query is subsequently 
deployed is different than the context in which it was defined. For example, when the 
query is defined, the levels in an example hierarchy may be company, division, 
department, and class; however, when the query is subsequently used the levels may 
have been modified to just division, department, class (for example, because a smaller 
10 "segment" of the plan was loaded). If the user wants the member selection or other 
action to occur at the "division" level, the user can use the explicit selection of the 
level, such that a change in the hierarchy will not affect this action. However, if the 
users wants the action to always apply to the level below the top level ("division" in 
the first context, but "department" in the second context), the user can use the relative 
1 5 form of selecting the level. 

A level may be selected using a LEVELSELECT command in combination 
with a specified leveljd as follows: 

LEVELSELECT: leveljd 

20 

A LEVELSELECT command may be included in a member selection script when a 
user uses a level selection box 108 or other selection tool of interface 100 to select a 
level. Each of the levels that are defined in the active hierarchy within the current 
context are available for selection. Selecting or de-selecting a level affects the way 

25 that expansion of a member within tree 1 10 is treated. If a level is not selected, then 
the members at that level are omitted from tree 110 when their parent is expanded. 
The descendant members at the next lowest selected level will be added to tree 110 
(assuming it is selected). The selected levels also determine to which levels the 
members are expanded when executing the MEMBEREXPAND command, which is 

30 described below. If a level was previously selected then the level remains selected 
upon its reselection using this command. 

A level may be deselected using the following command: 
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LEVELDESELECT: level id 



Any members previously selected at the level being deselected will become 
5 deselected. A LEVELDESELECT command may be included in a member selection 
script when a user uses a level selection box 108 or other selection tool of interface 
100 to deselect a level. 

A level may also be selected or deselected based on the previous state of the 
level as follows: 



This command selects a level if it was previously deselected and deselects a level if it 
was previously selected. 



children of a member. Such a member expansion may be performed by and recorded 
using the following command: 

MEMBEREXPAND: membercode [DEPTH=CHILDREN\ numeric\ BOTTOM] 

20 

This command marks (for example, using a flag) a member as being expanded. The 
DEPTH parameter defines how far down in the hierarchy to expand to. This 
parameter may only operate on the active levels. DEPTH=CHILDREN may be the 
default and should expand the member to the next level down. DEPTH=numeric 
25 defines how many levels down the hierarchy to expand to. For example, if DEPTH=2 
is specified, it means expand the member to show its children and its grandchildren. 
DEPTH=BOTTOM means expand to the lowest level in the hierarchy. Again, this 
parameter may only apply to the active levels defined by prior LEVELSELECT 
commands. 

30 In a similar manner, members may be collapsed using the following 



10 



LEVELTOGGLE: level id 



15 



As described above, a user may also expand one or more members to view the 



command: 
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MEMBER COLLAPSE: membercode 



If children members of a member to be collapsed were previously expanded, then 
their expanded state should be retained. 
5 When the user has selected a hierarchy, selected appropriate levels in the 

hierarchy, and/or expanded or collapsed particular members of the selected hierarchy, 
the user may select one or more members (although the user may select members 
before, after, or without performing any of these other actions). The selection of a 
member may be performed by and recorded using the following command: 

10 

MEMBERSELECT: membercode 



A MEMBERSLECT command may be added to a member selection script when a user 
selects a member by clicking on the member or its parent in tree 110 (or otherwise 
15 selecting the member). If the member is collapsed, this command marks as selected 
all of the member's descendents in the tree (note that the descendent members may 
expanded even though the parent is collapsed). If a selected member is expanded, 
then there is no change to the selection state of its descendents. 
A similar command may be used to deselect a member: 

20 

MEMBERDESELECT: membercode 



If the specified member was previously de-selected, then it should remain de-selected. 
If the member is collapsed, the member and all its descendents in the tree are marked 
25 as deselected (note that the descendent members may expanded even though the 
parent is collapsed). If the member is expanded, then there is no change to the 
selection state of the descendents. 

Another command may be used to toggle the selection state of a member as 
follows: 



MEMBERTOGGLE: membercode 
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This command switches a member as being either selected or deselected depending on 
the previous selection state of the member. The functionality is equivalent to the 
MEMBERSELECT and MEMBERDESELECT commands. 

The following is a sample script that may be created based on a user's actions 
in interface 100 (alternatively, the user may manually create the script in whole or in 
part): 



HIERSELECT: STANDARD 
LEVELDESELECT: SUB-CLASS 
10 MEMBERSELECT: Dl 
MEMBEREXPAND: Dl 
MEMBERDESELECT: C2 
MEMBEREXPAND: CI 
MEMBERDESELECT: SI 

15 

FIGURE 5 illustrates an example hierarchy 200 upon which this example 
member selection script operates (the "standard" hierarchy specified in the script). 
Hierarchy 200 includes four levels: department level 202, class level 204, sub-class 
level 206, and style level 208. As an example only, these may be levels in a standard 

20 hierarchy of a product dimension associated with clothing product data. Department 
level 202 has one member: Dl. Class level 204 has two members: CI and C2. Sub- 
class level 206 has three members: SCI, SC2, and SC3. Style level 208 has seven 
members: SI, S2, S3, S4, S5, S6, and S7. The hierarchical relationships of these 
various member are illustrated in FIGURE 5. 

25 Upon execution of the above script, the following members will be selected 

(and are indicated by hatching in FIGURE 5): Dl, CI, S2, S3, and S4. The script 
causes the following actions to be taken to reach this set of selected members (and 
these actions may reflect previous user actions in interface 100 that were recorded in 
the example script above). First, the illustrated hierarchy is selected. Sub-class level 

30 206 is then deselected so that it is not included in tree 1 10 of interface 100 (the other 
levels are selected by default). Next, member Dl is selected. Since Dl was not 
previously expanded, all of the descendants of Dl are also automatically selected 
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(except those members in sub-class level 206, which was deselected). Dl is then 
expanded such that its children, CI and C2 are shown in tree 110. Next, C2 is 
deselected. Since C2 is collapsed, deselecting C2 also deselects its descendants that 
were already selected (in this example, S5, S6, and S7 - SC3 was never selected since 
5 level 206 was deselected). CI is then expanded to show the descendants at the next 
selected level, SI, S2, S3, and S4. SI is then deselected, leaving Dl, CI, S2, S3, and 
S4 as the selected members of hierarchy 200. 

Based on an understanding of how a message selection script is created, a user 
may choose a way of selecting particular members that will produce a desirable 

10 member selection even when it is executed after the relevant hierarchy has been 
modified. The example script represents one technique by which a user may select 
particular members of style level 208 (as well as other members) through a sequence 
of actions by the user. This sequence affects what members are selected if the 
members included in style level 208 changed. For example, if another child of 

15 member SCI were added to level 208, this child would end up being selected using 
example script (since the user had to explicitly deselect SI given the previous actions 
the user had taken). However, the same member selection could have been generated 
using a different sequence of actions. For instance, if Dl was expanded before being 
selected, then no members in level 208 would have been selected through the 

20 selection of Dl. Afterwards, the user could have expanded CI and selected particular 
grandchildren of CI (for example, S2, S3, and S4, but not SI). In this case, if a new 
child was later added under SCI, this child would not be selected when the user's 
actions are reproduced using a member selection script (unlike if the example script 
above was used). Therefore, the user is able to control the affect of changes in a 

25 hierarchy on the members of the hierarchy that are selected based on the user's 
actions that have been recorded in a script. 

FIGURE 6 illustrates an example method for creating and reproducing 
member selections. The method begins at step 300 where system 10 communicates a 
member selection interface 100 to a user. As described above, member selection 

30 interface 100 may include numerous tools allowing the user to take various actions 
associated with the selection of members in a hierarchy. Member selection interface 
100 may be communicated to the user using any suitable technique. As an example, 
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member selection interface 100 may be displayed to the user as a web page or pages 
and communicated to the user as an HTML file, an XML file, an applet, a script, or 
any other appropriate mechanism for generating web pages. The user may provide 
input by using the web page and an associated web browser to communicate with a 
5 web server or other appropriate component. Alternatively, member selection interface 
100 may have any other appropriate format and information may be communicated to 
and received from the user using any suitable technique. For example, member 
selection interface 100 may be a desktop user interface provided by an application 
executing locally on a computer. 

10 At step 302, system 10 receives from the user a selection of a dimension from 

which members are to be selected. System 10 may also receive a selection of a 
hierarchy of the selected dimension from the user at step 304. At step 306, system 10 
may further receive an indication from the user of one or more levels of the hierarchy 
that are to be displayed to the user when selecting members of the hierarchy. This 

15 indication may be the express selection or deselection of particular levels in the 
hierarchy (and the default may be that all levels are selected). Based on these 
selections (although some or all of these selection steps may not be performed by the 
user and are not required), system 10 communicates a member selection tree 110 to 
the user at step 308. Member selection tree 110 may be displayed to the user in 

20 member selection interface 100, as described above. Member selection tree 110 
displays the members included in the selected levels in the selected hierarchy of the 
selected dimension. 

At step 310, system 10 receives requests from the user to perform various 
actions on member selection tree 110 associated with the selection of one or more 

25 members. As described above, these actions may include the expansion, collapsing, 
selection and/or deselection of one or more of the members in tree 1 10. Furthermore, 
as described above, these requests are received in a particular sequence that affects 
which members are eventually selected. System 10 records some or all of the user 
input described above in a member selection script at step 312. This user input may 

30 include the selection of one or more dimensions, hierarchies, and/or levels, as well as 
the expansion, collapsing, selection, and/or deselection of one or more members. The 



D 4 <£T ~ . ENT APPLICATION 

020431.1081 

24 

user input may be recorded in a script as it is received or the input may be temporarily 
stored and then recorded after the user has finished with the member selection. 

As described above, the user's action may be reproduced at a later time to 
create a member selection. This is true even if the relevant member hierarchy has 
5 changed. At step 314, system 10 receives a request from a user, a component of 
system 10, or any other appropriate source to reproduce a user's previous member 
selections using a script. System 10 executes the script at step 316 to reproduce the 
recorded users actions and to generate a set of selected members from a hierarchy, 
and the method ends. The script may be executed as many times as desired to 

10 reproduce the recorded actions. 

As an alternative to member selection interface 1 00, the user may manually 
create a script. For example, the user may determine the sequence of actions that 
should be performed to select one or more members and the user may then "program" 
these action into script. For example, the user may use a word processor or other 

1 5 appropriate tool to generate the script using the commands described above or other 
appropriate commands (and the script may be compiled or otherwise manipulated to 
make it executable, if necessary). Furthermore, a user may modify a script that was 
automatically or manually generated. 

Although the present invention has been described with several embodiments, 

20 numerous changes, substitutions, variations, alterations, and modifications may be 
suggested to one skilled in the art, and it is intended that the invention encompass all 
such changes, substitutions, variations, alterations, and modifications as fall within the 
spirit and scope of the appended claims. 



